草庐IT

Android JsonArray 和 JsonObject 反序列化

全部标签

c++ - 使用 boost 序列化抽象类时出错

我正在尝试序列化我的数据结构,以便将它们写入tcp套接字。到目前为止我发现我的问题是序列化。我什至尝试使用BOOST_SERIALIZATION_ASSUME_ABSTRACT(T)但我找不到任何与我的程序相似的工作示例以及如何正确实现它。以下是我访问过的一些链接:http://programmers-blog.com/category/c-chttp://www.boost.org/doc/libs/1_48_0/libs/serialization/doc/tutorial.html#simplecasehttp://en.highscore.de/cpp/boost/serial

c++ - Boost模板派生类的序列化

我有一个模板化基类Base和一个模板化派生类Derived,我想将其序列化。下面的简化代码编译并运行但不序列化基类的数据成员。#include#include#include#include#include#include#include#include#includetemplatestructBase{Base(Uuu,Vvv):u(uu),v(vv){}Uu;Vv;};templatestructDerived:publicBase,publicBase{Derived(Ttt):Base(2.0,4),Base(3.0,std::string("hello")),t(tt){}

c++ - 捕获 boost 序列化存档异常

我有以下情况。这是一个代码片段,经过编辑以演示问题。ifstreamifs("empty_file");if(!ifs.is_open()){ui.display("Error:Unabletoopenfile\"empty_file\"\n");return;}archive::text_iarchiveia(ifs);try{ia>>some_class;}catch(...){ui.display("Thisshouldcatcheversingleexception\n");}empty_file确实是一个完全空的文件。这应该会导致错误;确实如此。问题是我无法捕获boost抛出

c++ - Qt - 序列化 "double"时出现问题

我序列化“double”数据类型并得到一个错误QDataStream&operator运算符已定义。这是错误消息:error:conversionfrom'double'to'constQChar'isambiguous您遇到过这种情况,或者理解为什么会变成这样吗? 最佳答案 听起来它看不到double的运算符,因此它试图从double隐式创建一个QChar以发送到流,但是QChar有可能匹配的多个构造函数。确保您的header包含的内容都是正确的。你能告诉我们你试图序列化替身的代码吗?

解决BigDecimal序列化科学计数法前端展示问题(大坑)

解决BigDecimal序列化科学计数法前端展示问题(大坑)前言:在生产中出现一个问题,就是BigDecimal类型的字段在前端页面展示变成科学计数法,通过排查,发现里面的坑还是挺多的,所以特意记录下处理过程。Json序列化,不同项目中配置的都不一样,有些项目是使用springboot里面自带的jackson的,有些是使用fastjson处理,不同的序列化的处理方式也不一样。1、fastJson对BigDecimal序列化和反序列化字段返回完整的数字,避免科学计数法我们看下JSON.toJSONString()的方法,我们可以看到,可以传进SerializerFeature的枚举publics

c++ - 使用单独的 .h 和 .cpp 文件 boost 序列化

我正在试验boost序列化库,并且大部分都可以正常工作。唯一的问题是当我尝试序列化具有单独的.h和.cpp文件的对象时。当我使用这个命令编译时:g++boostSerialize.cppClass.cpp-lboost_serialization我收到这个错误:/tmp/cc8kbW6J.o:Infunction`voidboost::serialization::access::serialize(boost::archive::text_oarchive&,Class&,unsignedint)':boostSerialize.cpp:(.text._ZN5boost13seria

python - 序列化 C++ 对象以通过套接字发送到 Python - 最佳方法?

我需要在两个不同的框架之间创建网络通信,一个用C++编写,另一个用Python编写。为了交换数据​​,我想在C++中创建某种灵活的结构(基本上是一个结构),它被序列化,通过套接字发送到Python,然后反序列化.最常用的方法是什么?我确信Boost可以在任何一方做到这一点,因为有boostpython,但我不想把项目要求搞得那么大。那么除了指定自己的二进制数据格式之外,是否有更小的库或任何其他优雅的解决方案?更新:下面是一个示例,如何使用Google的protobuf通过将数据结构从C++脚本发送到Python脚本>UDP。这在MacOSXMavericks上进行了测试,但在其他Uni

c# - 使用由 google 的 protobuf 序列化的 protobuf-net 反序列化数据时出现问题

我目前正在处理在一个应用程序(C++)中序列化并需要在另一个应用程序(C#)中反序列化的代码。我正在尝试使用googleproto+protobuf-net但出现问题。.cc和.cs消息定义文件都是使用各自的编译器从同一个.proto文件生成的。数据通过UDP发送,消息(~40B)很容易放入单个数据报中。在C++大小上,使用boost::asio传输数据,相关代码为:ProtocolBufferdatadata;...boost::asio::streambufb;std::ostreamos(&b);data.SerializeToOstream(&os);m_Socket.send

c++ - 如何序列化 boost::dynamic_bitset?

如何使用boost::dynamic_bitset成员序列化一个类?#include#include#include#include#includeclassA{friendclassboost::serialization::access;boost::dynamic_bitsetx;templatevoidserialize(Archive&ar,constunsignedint){ar&x;}};intmain(){Aa;std::stringstreamss;boost::archive::text_oarchiveoa(ss);oa编译报错(boost1.57)Infilei

c++ - Boost C++ 序列化一个 char *

我有一个类,我正在尝试序列化一个shared_ptr,但序列化对象的常规方法不起作用:classObject{public:Object();~Object();shared_ptrobjectone;friendclassboost::serialization::access;templatevoidserialize(Archive&ar,constunsignedintversion){ar&objectone;}};我什至尝试过这种方式,但它仍然不起作用:voidserialize(Archive&ar,constunsignedintversion){for(inti=0;